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Foreword 



rd , 



The present document has been produced by the 3 Generation Partnership Project (3 GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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1 Scope 



The present document contains an electronic copy of the ANSI-C code for the eCall in-band modem solution for 
reliable transmission of MSD data from IVS to PSAP via the speech channel of cellular networks. The ANSI-C code is 
necessary for a bit exact implementation of the IVS modem and PSAP modem described in 3GPP TS 26.267 [1]. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] 3GPP TS 26.267: "eCall Data Transfer; In-band modem solution; General description". 

See also the references in 3GPP TS 26.267 [1]. 



3 Abbreviations 

For the purpose of the present document, the following abbreviations apply: 

ACK ACKnowledgement 

ANSI American National Standards Institute 

CRC Cyclic Redundancy Check 

FEC Forward Error Correction 

GSM Global System for Mobile communications 

HARQ Hybrid Automatic Repeat-reQuest 

I/O Input/Output 

IVS In- Vehicle System 

MSD Minimum Set of Data 

NACK Negative ACKnowledgement 

PCM Pulse Code Modulation 

PSAP PubHc Safety Answering Point 

RAM Random Access Memory 

ROM Read Only Memory 

RX Receive 

TX Transmit 



4 C code structure 

This clause gives an overview of the structure of the bit-exact C code and provides an overview of the contents and 
organization of the C code attached to the present document. 

The C code has been verified on the following systems: 

• Windows XP SP2 and Microsoft Visual Studio V8.0; 

• Linux (Suse Linux) using the gcc v3.4.2 and v4.L2 compilers. 
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4.1 



Contents of the C source code 



The distributed files with suffix "c" contain the source code and the files with suffix "h" are the header files. 
Further explanation on the files is given in the readme . txt file, which is reproduced in part here: 

Package Contents 



folder ' ecall ' : 

Contains the complete eCall ANSI C fixed-point reference source code. 

modem_ivs . c : top-level modem implementation for TVS 
modem_psap.c : top-level modem implementation for PSAP 

modemx.h : header file for both modem_ivs . c and modem_psap.c 

ecall_def ines .h : compile time options and preprocessor constants 



ecall_control . h 
ecall_f ec .h 
ecall_modem.h 
ecall_sync .h 
ecall_rom.h 

ecall_control . c 
ecall_f ec . c 
ecall_modem. c 
ecall_sync . c 
ecall rom.c 



header file control message handling 
header file FEC encoder and decoder 
header file modulator and demodulator 
header file synchronization 
header file ROM data 

control message handling 
FEC encoder and decoder 
modulator and demodulator 
synchronization 
ROM data 



folder ' test_setup ' : 

Contains the eCall software simulation framework, to be compiled 
and run on MS Windows systems . 

folder 'test_vec': 

Contains binary PCM data (104 files) and receiver/transmitter port logs 
in ASCII format (104 files) to test the eCall IVS and PSAP modems. 

The PCM format is 16 bit signed, little endian, at 8 kHz sampling rate. 
The data files reflect 26 test cases and were generated from the eCall 
simulation framework. 



campaign_short . txt 

pcmdlout<index> .pcm 
pcmulout<index> .pcm 

pcmdlin<index> .pcm 
pcmulin<index> .pcm 

portivsrx<index> . txt 
portivstx<index> . txt 

portpsaprx<index> . txt 
portpsaptx<index> . txt 



configuration file for the 26 test cases 

output PCM data of DL vocoder = input to IVS 
output PCM data of UL vocoder = input to PSAP 

test vectors for PSAP modem output 
test vectors for IVS modem output 

test vectors for IVS port logs (receiver) 
test vectors for IVS port logs (transmitter) 

test vectors for PSAP port logs (receiver) 
test vectors for PSAP port logs (transmitter) 



standalone . c 

mainO wrapper to run the IVS or PSAP modem on prestored PCM files or 
receiver/transmitter port logs. To get a list of command- line options, 
invoke the corresponding executable with option '-h' (help). 

standalone .h 

header file for standalone. c 



Makefile .win 
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Microsoft Visual Studio 2005/2008 Makefile 

Builds 'standalone.exe' from standalone. c and the eCall sources, 

build options are RELEASE and DEBUG. 

Makefile .glx 

GNU Linux Makefile using gcc 

Builds 'standalone' from standalone. c and the eCall sources, 

build options are RELEASE and DEBUG. 

verify.bat 

Windows batch file 

Runs 'standalone.exe' in six different modem modes on the 26 test cases 
contained in folder ' test_vec ' and performs a test vector comparison to 
the respective output PCM and port log data. 

verify. sh 

Linux shell script 

Runs 'standalone' in mode ' -m ivs ' and ' -m psap ' on 26 test cases 
(folder 'pcm') and performs a test vector comparison to the respective 
modem output PCM data . 



4.2 Program execution 

An explanation on code compilation and execution is given in the readme . txt file, which is reproduced in part here: 

Getting Started 



3GPP TS 26.268 provides the eCall modem source code, a software simulation 
framework, and a standalone wrapper that allows to run the IVS or PSAP modem 
on prestored reference data. 

The following functions represent the eCall modem interface and invoke the 
respective receiver and transmitter implementation of each modem: 

* void PsapResetO; 

* void PsapProcess (Intl6 *pcm) ; 

* void PsapSendStart ; 

* void PsapSendHlack (const OrdS data) ; 

* void IvsReset (const OrdS *msd, int length); 

* void IvsProcess (Intl6 *pcm) ; 

* void IvsSendStart ; 

The external application must in addition implement the callback functions: 

* void PsapReceiveMsd (const OrdS *msd, int length); 

* void IvsReceiveAck ( ) ; 

* void IvsReceiveHlack (const OrdS data); 

* void Abort (const char * format, ...); 

* void Loglnfo (const char * format, ...); 

They will be called 

a) by the PSAP modem once the complete MSD was successfully received, 

b) by the IVS modem on reception of the lower- layer ACK, 

c) by the IVS modem on reception of the HLACK message. 

Abort and Loglnfo should implement a variadic error and print log handler, 
respectively. See standalone. c for sample implementations of all callback 
functions . 

For a real-time simulation over 3GPP FR and AMR vocoders and to log PCM data 
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as input to the standalone wrapper, the eCall sources have to be integrated into a 

simulation framework; folder 'test_setup' contains the one as used in 

the 3GPP selection tests. The basic integration steps are briefly described 

below. 

In order to compile and run the eCall modem code, follow the instructions 
given below. For code testing, two batch files have been provided: 

* verify.bat : MS Windows systems 

* verify. sh : Linux systems 

For each of the 26 test cases of campaign_short.txt in folder ' test_vec ' , 
they run the standalone wrapper in six different modem modes (three TVS and 
three PSAP modes) . The resulting PCM and port log files in folder 'out' are 
finally compared to the test vectors in folder ' test_vec ' . 

In modes 'psap' and 'psaprx', you should see an MSD success message at the 
end of each test case. 

Code Compilation 



MS Windows systems 

To build standalone.exe from standalone. c and the eCall sources, start 
with opening a new project in Visual Studio 2005/2008. 

Choose File -> New -> 'Project from Existing Code' and follow the 
instructions of the 'Create Project from Existing Code Files Wizard'. 
Configuration : 

* Type of project: Visual C++ 

* Specify the folder location of standalone. c and a project name 

* Button 'Next' 

* Select 'Use external build system' 

* For Debug and Release configuration, specify 

Build command line: nmake -f Makefile. win 
Clean command line: nmake -f Makefile. win clean 

Build the project with shorthand key ' F7 ' or from the menu. 

The source code should compile without any errors or warnings. 

Run 'verify.bat' to verify the executable against the test vectors. 

GNU Linux systems 

Compilation under Linux has been tested with 

* GNU Make version 3.81 

* gcc version 4.1.3 and 4.2.4 

For building the executable 'standalone' and cleanup, use 

make -f Makefile. glx 

make -f Makefile. glx clean 

On the platforms tested, the code compiled without errors or warnings. 
Run ' verify. sh' to verify the executable against the test vectors. 



Simulation Framework 

The eCall software simulation framework is provided in folder 'test_setup' 
Important remarks : 

* See LICENSE.TXT and README.TXT for terms of usage! 

* The G.711 software is part of ITU-T Rec . G.191, (C) ITU 2000. 
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Distributed with the authorization of ITU as part of the test setup 
software for 3GPP TS 26.268. 

* The framework must be compiled and run on MS Windows systems, as the 
FR and AMR vocoders are attached to it in form of Windows executables 
and via Windows specific API functions. 

To attach the eCall sources to the framework: 

* Copy the ' ecall ' folder into subf older 'c' of ' test_setup ' . 

* Compile and link the *.c files under subf older 'ecall' by adding their 
corresponding object files to the list of makefile targets. 

* In the makefile, replace the source code template modem_demo . c by both 
modem_ivs . c and modem_psap . c . 

The framework has the callback functions PsapReceiveMsd, Abort, and Loglnfo 
already implemented. 

4.3 Variables, constants and tables 

4.3.1 Description of constants used in the C-code 

This clause contains a listing of all global constants defined in ecall_de fines . h., together with some explanatory 
comments. 



Constant 



Value 



Description 



#define MAX(a,b) 
#define ]y[IN(a,b) 
#define ABS (a) 
#define SIGN (a) 



(a)>(b) ? (a) : (b)) 

(a)<(b) ? (a) : (b)) 

(a)<0 ? (-a) : (a)) 

(a)<0 ? (-1) : (D) 



#define PCM_LENGTH 
#define MSD MAX LENGTH 



160 
140 



length of PCM frame 

length of MSD message (bytes) 



/* Synchronization */ 
#define SYNC_BADCHECKS 
#define SYNC_IDXLEN 
#define SYNC THRESHOLD 



(8) 

(75) 

(10e6) 



IVS subsequent bad checks 
sync index length 
sync threshold 



#define LOCK_START_UL 
#define LOCK START DL 



(2) 
(3) 



START messages to lock sync (UL) 
START messages to lock sync (DL) 



#define FAIL RESTART 



(3) 



number of START messages to restart 



#define NRF_WAKEUP 
#define NRF_SYNC 
#define NRF OBSERVE 



(3) 

(13) 

(10) 



number of wakeup frames 
length of sync in frames 
number of frames the PSAP checks for a 
better sync after detecting a preamble 



#define PNSEQ_OSF 
#define PEAK_DIST_PP 
#define PEAK_DIST_NN 
#define PEAK_DIST_PN 

/* Uplink/Downlink format */ 
#define ARQ_MAX 
#define NRB_TAIL 
#define NRB CRC 



(22) "over sampling" rate of PN sequence 

(3 0*PNSEQ_OSF) distance outer positive peaks 

(54*PNSEQ_OSF) distance negative peaks 

(12*PNSEQ_0SF) distance positive to negative 



(3) 
(28) 



number of redundancy versions 
number of encoder tail bits 
order of CRC polynomial 



#define NRB_INFO 
#define NRB_INFO_CRC 
#define NRB_CODE_ARQ 
#define NRB CODE BUFFER 



( 8 *MSD_MAX_LENGTH) 

(8*MSD_MAX_LENGTH + NRB_CRC) 

(1380) 

(3*(8*MSD MAX LENGTH + NRB CRC) 



+ 4*NRB TAIL) 



#define SET_LLMSG 
#define SET HLMSG 



(16) 
(16) 



set size lower-layer messages 
set size higher-layer messages 
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#define NRF_DLDATA 
#define NRF_DLMUTE1LL 
#define NRF_DL]y[UTElHL 
#define NRF DLCHUNK 



(3) downlink data frames 

(2) 1st muting lower-layer message 

(1) 1st muting higher- layer message 

(NRF SYNC + NRF DLMUTEIHL + 2*NRF DLDATA) 



/* IVS/PSAP processing */ 
#define NRF_ME]y[CTRL 
#define NRS MEMSYNC 



(7) 
(820) 



buffer size in frames 

memory size in samples (SYNC) 



#define IVS_THRESHOLD 
#define IVS_GOSTART 
#define IVS_TXFAST 
#define IVS_TXINC 

#define PSAP_NUMSTART 
#define PSAP_NUMACK 
#define PSAP_NUMHLACK 
#define PSAP_THRESHOLD 

#define FEC_VAR 
#define FEC_MEAN 
#define FEC_ITERATIONS 
#define FEC STATES 



(40000) 
(6) 
(10) 
(87) 



threshold for control messages 
threshold for unreliable START 
fast modulator mode NACK condition 
sample increment at restart 



(20) number of START messages 

(20) number of ACK messages 

(5) number of PSAP HLACK messages 

(40) threshold for modulator type 

(30206) variance: 1/4550000 in Q37 

(0xB9999A) mean: 5.8 in Q21 

(8) number of decoder iterations 

(8) number of decoder states 



#define IntLLR Intl6 

#define LLR_]y[AX ((Int32) 

#define LOGEXP_RES (401) 

#define LOGEXP_DELTA (-6) 

#define LOGEXP_QIN (8) 

4.3.2 Type Definitions 



size of soft bit buffer variables 
(Ox7fff-l) ) 

resolution of LOGEXP table 
determines internal Q- factor 
input Q- factor of LLR values 



The following type definitions have been used, which are defined in ecall_defines.h, ecall_modem.h, ecall_sync.h, and 
modemx.h: 



Definition 



Description 



typedef enum { False, True } Bool; 

typedef enum { Minus = -1, 
Zero, 
Plus } Tern; 

typedef signed char Int8; 
typedef signed short int Intl6; 
typedef signed int Int32; 

typedef unsigned char Ordl ; 

typedef unsigned char Ord8 ; 

typedef unsigned short int Ordl6; 

typedef unsigned int Ord32; 

typedef enum { 

ModUndef , 

]y[od3bit4smp, 

Mod3bit8smp 
} ModType ; 



boolean variable 



ternary variable 

8 bit signed variable 
16 bit signed variable 
32 bit signed variable 

binary symbol 
8 bit unsigned variable 
16 bit unsigned variable 
32 bit unsigned variable 



modulator type for uplink transmission 



typedef 


struct { 


ModType type ; 


Intl6 


bpsym; 


Intl6 


spmf ; 


Intl6 


mfpf ; 


Intl6 


decposl ; 


Intl6 


decpos2 ; 


Intl6 


wutperiod; 


Intl6 


nfmutel ; 


Intl6 


nf mute4 ; 


Intl6 


nfmuteall ; 


Intl6 


nfdata; 



identifies modulator type 

bits per symbol 

samples per modulation frame 

modulation frames per frame = PCM_LENGTH/spmf 

position 1st decoding trial 

position 2nd decoding trial 

wakeup tone period in samples 

number of muting frames 1st interval 

number of muting frames 4th interval 

number of muting frames total 

number of data frames = NRB_CODE_ARQ/ (mfpf *bpsym) 
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const Intl6 *ulPulse; 
const Intl6 *ulPulse]y[atch; 
const Intl6 *mgTable; 
const Intl6 *wakeupSin; 
const Intl6 *wakeupCos; 
} ModState; 

typedef struct { 
Int3 2 *mem; 
Int32 *memWakeup; 



Int32 amplitude [3] 
Intl6 corrIndex[4] 
Int32 corrCheck[4] 
Intl6 peakPos [4] ; 

Bool flag; 
Intl6 delay; 
Intl6 tempDelay; 
Intl6 prevDelay; 
Intl6 trials; 
Intl6 npeaks; 
Intl6 events; 



modulator state for uplink transmission 



memory for sync 

memory for wakeup tone detector 

amplitudes (average, maximum, memory) 

sync check positions 

sync check correlation values 

sync peak positions within control message 

indicates successful sync 

synchronization delay (position) 

temporary delay in two- stage peak evaluation 

previous sync delay 

number of sync trials 

number of sync peaks detected 

number of subsequent equal sync events 



Tern check; 
Intl6 checkCnt; 
Intl6 index; 
Intl6 offset; 
} SyncState; 

typedef enum { 

DlNoop = -2, 

DlTriggerReset , 

DlMsgStart, 

DlMsgNack, 

DlMsgAck, 

DlMsgHlack = SET_LL]y[SG 
} DlData; 



typedef enum { 
Ivsldle, 
IvsTrigger, 
IvsStart , 
IvsSendMsd, 
IvsAck 

} IvsState; 



typedef struct { 
CtrlRxData Ctrl; 
SyncState sync; 



indicates sync check result (ternary variable) 

counter for subsequent sync check failures 

frame reference for sync evaluation 

frame offset 

state of synchronization functions 



downlink message identifiers 



TVS state identifiers 



TVS control struct 
TVS sync struct 



Intl6 state; 

Intl6 dlData; 

Intl6 dllndex; 

Intl6 dlMsgCnt; 

Intl6 memCtrl [NRF_]y[E]y[CTRL*PC]y[_LENGTH] 
Int32 memSync [NRS_]y[E]y[SYNC] ; 
} IvsRxData; 

typedef struct { 
CtrlTxData Ctrl; 
ModState mod; 
Intl6 state; 
Intl6 stateCntNack; 
Bool startPending; 



receiver state 
downlink message symbol 
donwlink frame counter 
downlink message counter 



TVS control struct 

TVS modulator struct 

transmitter state 

global NACK counter 

indicates pending START message 



Intl6 delay; 
Intl6 rv; 



transmit offset in samples 
redundancy version 
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Intl6 ulN; 
Intl6 ul Index; 
Intl6 ulDelay; 

Intl6 stateCnt [SET_LL]y[SG + 1] ; 
Intl6 stateIgn[SET_LL]y[SG + 1] ; 

Ordl memCode [NRB_CODE_BUFFER] 
Intl6 memDelay [2*PC]yi_LENGTH] ; 
} IvsTxData; 

typedef struct { 

IvsRxData rx; 

IvsTxData tx; 
} IvsData; 

typedef enum { 

Psapldle, 

PsapTrigger, 

PsapStart , 

PsapNack, 

PsapAck, 

PsapHlack, 
} PsapState; 

typedef struct { 
CtrlRxData Ctrl; 
SyncState sync; 
ModState mod; 



uplink number of frames 

uplink frame counter 

uplink transmit offset in samples 

state counters 

counter for unreliable messages 



IVS receiver struct 
IVS transmitter struct 



PSAP state identifiers 



PSAP control struct 
PSAP sync struct 
PSAP modulator struct 



Intl6 state; 

Intl6 rv; 

Intl6 ulN; 

Intl6 ul Index; 

Intl6 mglndex; 

Intl6 ulTrials; 

Intl6 ulSyncTail; 



receiver state 

redundancy version 

uplink number of frames without muting 

uplink frame counter 

uplink position in muting gap table 

uplink decoding trails 

sync observation counter after sync success 



OrdS dlHlackData; 
Intl6 dlData; 
Intl6 dl Index; 
Intl6 dlMsgCnt; 



downlink higher- layer message 
downlink message symbol 
donwlink frame counter 
downlink message counter 



(4 bits) 



OrdS *msd; 
Ordl *msdBin; 
Intl6 *memCtrl; 
IntLLR *memCode; 



MSD in byte representation 

MSD in binary representation 

buffer for control and data demodulation 

soft bit buffer for decoding 



char buffer [0 

+ sizeof (IntLLR) 
+ sizeof (Intl6) 
+ sizeof (Int32) 
+ sizeof (Int32) 
} PsapRxData; 

typedef struct { 

CtrlTxData Ctrl; 
} PsapTxData; 

typedef struct { 
PsapRxData rx; 
PsapTxData tx; 
Intl6 msgCounter; 

} PsapData; 

typedef enum { 
CtrlRxIdle, 
CtrlRxSync, 
CtrlRxLock, 
CtrlTxIdle, 



NRB_CODE_ARQ 

NRF_]y[E]y[CTRL* PC]y[_LENGTH 

NRS_]y[E]y[SYNC 

2* (NRF SYNC+1) ] ; 



PSAP control struct 



PSAP receiver struct 
PSAP transmitter struct 
message counter 
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CtrlTxSend 
} PortState; 

typedef struct { 
Intl6 dlData; 
Intl6 dl Index; 

} CtrlTxPort; 

typedef struct { 
Intl6 dlData ; 
Intl6 dlMetric; 

} CtrlRxPort; 



message symbol 
message frame counter 



detected message symbol 
receiver metric 



typedef struct { 
CtrlPort port; 
} CtrlTxData; 

typedef struct { 
CtrlPort port; 

SyncState *sync; 
Intl6 *buffer; 

OrdS dlHlackData; 
Tern dlRead; 
Intl6 dllndex; 
Intl6 dlSyncLock; 
} CtrlRxData; 



port struct 



port struct 

pointer to sync struct 

pointer to control receiver buffer 

downlink higher-layer message (4 bits) 
sync indication (ternary variable) 
internal frame counter 
number of sync events required 



4.3.3 Description of fixed tables used in the C-code 

This clause contains a listing of all fixed tables (ROM) defined in ecall_rom . c. 

Type/Constant Dimension Description 

/* Synchronization */ 
Intl6 wakeupSinSOO 
Intl6 wakeupCosSOO 
Intl6 wakeupSinSOO 
Intl6 wakeupCosSOO 



Intl6 syncPulseForm 
Intl6 syncSequence 
Intl6 syncIndexPreamble 
Intl6 syncFrame 

/* Uplink/Downlink format */ 
Intl6 indexBits 

// fast modulator mode: 
Intl6 m4smp_ul Pulse 
Intl6 m4smp_ulPulse]yiatch 
Intl6 m4smp_mgTable 

// robust modulator mode: 
Intl6 m8smp_ulPulse 
Intl6 m8smp_ulPulse]yiatch 
Intl6 m8smp_mgTable 

Intl6 dlPcmData 
Intl6 dlPcmDataMatch 

/* EEC encoder/decoder */ 
Ordl6 stateTransMat 
Ordl6 stateTrans 
Ordl6 revStateTransMat 
Ordl6 revStateTrans 
Ordl outputParityMat 



[16] 




[16] 




[10] 




[10] 




[5] 




[15] 




[SYNC 


IDXLEN] 


[1600] 





[24] 



[16] 
[64] 
[54] 



sine waveform at 500 Hz 
cosine waveform at 500 Hz 
sine waveform at 800 Hz 
cosine waveform at 800 Hz 

sync pulse 

sync pulse sequence 

sync pulse positions 

predefined synchronization signal 



bit positions for turbo decoder 



uplink waveform 

matched filtered uplink waveform 

table indicating muting gaps 



[32] 

[128] 

[104] 

[4] [NRE_DLDATA*PCM_LENGTH] 
[4] [NRE DLDATA* PCM LENGTH] 



uplink waveform 

matched filtered uplink waveform 

table indicating muting gaps 

downlink transmit signal 
DL MF signal 



[8] [2] 
[16] 
[8] [2] 
[16] 
[8] [2] 



EEC 
EEC 
EEC 
EEC 
EEC 



State transitions 
state transitions 
reverse state transitions 
reverse state transitions 
output parity indicator 
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Ordl outputParity 

Ordl crcPolynomial 
Ordl scramblingSeq 
Ordl6 interleaverSeq 
Ordl6 redVerlndex 

IntLLR logExpTable 



[16] 

[NRB_CRC+1] 
[NRB_INFO_CRC] 
[NRB_INFO_CRC] 
[8] [NRB_CODE_ARQ] 

[LOGEXP RES] 



FEC: output parity indicator 

coefficients of CRC polynomial 
bit scrambling sequence 
interleaver sequence 
index vector for HARQ process 

loolcup table (logExp function) 



4.3.4 Static variables used in the C-code 

This clause contains a listing of static variables (RAIM) defined in source files. 
Definition Description 



IvsData ivs 

PsapData psap 

WordLLR chCodedSof tBitBuf f er [NRB CODE BUFFER] 



IVS static memory 

PSAP static memory 

soft bit buffer of turbo decoder 



4.4 



Functions of the C Code 



This clause contains the headers of the employed IVS and PSAP functions. They correspond to a large extent to the 
functional description of the IVS and PSAP provided in 3GPP TS 26.267 [1]. 

Figure 1 gives an overview of the most important functions and their hierarchical relation. 



ETSI 



3GPP TS 26.268 version 9.0.0 Release 9 



15 



ETSI TS 126 268 V9.0.0 (2010-01) 



IvsSendStart () 



IvsResetO : Rx and Tx 



CtrlTxReset ( ) 



Byte2Bit() 



FecEncode () 



AttachCRCO 



Scramble( ) 

En code Two () 
EncodeOne ( ) 



IvsProcess() : Rx and Tx 



Ctrl Sync ( ) 

- Sync ( ) 

- SyncCheckO 



IvsTXStateO 

- CtrlReceiver ( ) 

- SetModStateO 



IvsTransmitter ( ) 
SymbolModO 



PsapSendStart ( ) 



PsapResetO : Rx and Tx 

PsapProcess () : Rx and Tx 
PsapRxO : UL and DL 

- SyncO 

- SetModStateO 

PsapReceiver () 



Symbol Demod ( ) 
- JacLogO 



FecDecode ( ) 



UpdateBuff er () 



DecodeBuff er () 

- BcjrO 

- Interleave () 

- Deinterleave ( ) 



Descramble () 



DecodeCRC( ) 



Bit2Byte() 



PsapReceiveMsd () 



Psap Reset ( ) 



CtrlTransmitter ( ) 



Figure 1: Hierarchical function overview 

4.4.1 Interface functions 

/* IVS implementation: IvsReset */ 

/* */ 

/* Description: Reset of IVS before the reception of a new MSD */ 

/* */ 

/* In: const OrdS* msd -> MSD to be transmitted */ 

/* int length -> MSD length (equal to MSD_MAX_LENGTH) */ 
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void IvsReset (const OrdS *msd, int length) 

void IvsRxResetO 

void IvsTxReset (const OrdS *msd, int length) 



/* TVS implementation: IvsProcess */ 

/* */ 

/* Description: TVS modem function that processes the PCM data */ 

/* */ 

/* InOut : Intl6* pcm <-> input and output frame of 16bit PCM samples */ 

/* */ 

void IvsProcess (Intl6 *pcm) 

void IvsRxProcess (const Intl6 *pcm) 

void IvsTxProcess (Intl6 *pcm) 

/*^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/ 

/* TVS implementation: IvsSendStart */ 

/* */ 

/* Description: Initiates IVS to trigger the transmission of SEND messages */ 
void IvsSendStart ; 

/* IVS implementation: IvsReceiveAck */ 

/* */ 

/* Description: callback function indicating a received ACK message */ 

/* */ 

void IvsReceiveAck ; 

/*============================================================================*/ 

/* IVS implementation: IvsReceiveHlap */ 

/* */ 

/* Description: callback function indicating a received higher layer messages */ 

/* V 

/* In: const OrdS data -> data symbol identifierer */ 

/* */ 

void IvsReceiveHlap (const OrdS data) ; 

/* PSAP implementation: PsapSendStart */ 

/* */ 

/* Description: Initiates PSAP to trigger the transmission of an MSD */ 
void PsapSendStart ( ) 

/* PSAP implementation: PsapSendHlap */ 

/* */ 

/* Description: Initiates PSAP to send the higher layer messages */ 

/* */ 

/* In: const OrdS data -> data symbol identifierer */ 

void PsapSendHlap (const OrdS data) ; 

/* PSAP implementation: PsapReset */ 

/* */ 

/* Description: Reset of PSAP before the reception of a new MSD */ 

/* */ 

void PsapReset 
void PsapRxReset ( ) 
void PsapTxReset ( ) 
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/* PSAP implementation: PsapProcess */ 

/* */ 

/* Description: PSAP modem function that processes the PCM data */ 

/* */ 

/* InOut : Intl6* pcm <-> input and output frame of 16bit PCM samples */ 

/* */ 

void PsapProcess (Intl6 *pcm) 

void PsapRxProcess (const Intl6 *pcm) 

void PsapTxProcess (Intl6 *pcm) 



4.4.2 IVS transmitter functions 

/* IVS FUNCTION: IvsTransmitter */ 

/* */ 

/* Description: IVS transmitter function */ 

/* */ 

/* In: const ModState* ms -> modulator struct */ 

/* const Ordl* buffer -> code bit buffer */ 

/* Intl6 rv -> redundancy version */ 

/* Intl6 index -> position within uplink frame */ 

/* Out: Intl6* pcm <- output data */ 

/* */ 

void IvsTransmitter (const ModState *ms, const Ordl *buffer, Intl6 *pcm, 

Intl6 rv, Intl6 index) 

/* UTILITY FUNCTION: IvsTxState */ 

/* */ 

/* Description: IVS state machine evaluating feedback messages */ 

/* */ 

/* In: Intl6 msg -> new control message symbol */ 

/* Intl6 metric -> receiver metric (-1: ignore symbol) */ 

/* Bool syncLock -> indicates sync lock of control receiver */ 

/* */ 

void IvsTxState (Intl6 msg, Intl6 metric, Bool syncLock) 

/* IVS FUNCTION: SymbolMod */ 

/* */ 

/* Description: symbol modulator */ 

/* */ 

/* In: const ModState* ms -> modulator struct */ 

/* Intl6 symbol -> symbol index */ 

/* Out: Intl6* mPulse <- modulated output sequence */ 

/* */ 

void SymbolMod (const ModState *ms, Intl6 symbol, Intl6 *mPulse) 

/* IVS FUNCTION: Byte2Bit */ 

/* */ 

/* Description: conversion byte vector to bit vector */ 

/* */ 

/* In: OrdS* in -> vector of input bytes */ 

/* Intl6 length -> length of input */ 

/* Out: Ordl* out <- vector of output bits */ 

/* */ 

void Byte2Bit (const OrdS *in, Ordl *out, Intl6 length) 

/* ENCODER FUNCTION: FecEncode */ 
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/* */ 

/* Description: encoding of MSD */ 

/* */ 

/* InOut : Ordl *buffer <-> takes info bits and returns coded bits */ 

void FecEncode (Ordl *buffer) 

/* ENCODER FUNCTION: AttachCrc */ 

/* */ 

/* Description: attaches CRC bits */ 

/* */ 

/* In: const Ordl* infoBits -> input information bits */ 

/* Out: Ordl* infoWithCrc <- bits with CRC attached */ 

/* */ 

void AttachCrc (const Ordl *infoBits, Ordl *inf oWithCrc) 

/* ENCODER FUNCTION: Scramble */ 

/* */ 

/* Description: bit scrambling */ 

/* */ 

/* In: const Ordl* in -> non scrambled input bit sequence */ 

/* Out: Ordl* out <- scrambled output bit sequence */ 

/* */ 

void Scramble (const Ordl *in, Ordl *out) 

/* ENCODER FUNCTION: EncodeTwo */ 

/* */ 

/* Description: encoding of bit sequence */ 

/* */ 

/* InOut : Ordl* codedBits <-> scrambled bits to coded bits */ 

void EncodeTwo (Ordl *codedBits) 

/*============================================================================*/ 

/* ENCODER FUNCTION: EncodeOne */ 

/* */ 

/* Description: convolutional encoding of each component */ 

/* */ 

/* In: Intl6 encNr -> component number */ 

/* InOut; Ordl* codedBits <-> bits to be encoded */ 

/* */ 

void EncodeOne(Ordl *codedBits, Intl6 encNr) 



4.4.3 PSAP receiver functions 

/* UTILITY FUNCTION: PsapRxUplink */ 

/* */ 

/* Description: PSAP UL state machine, determines PSAP receiver operation */ 

/* according to the state */ 

/* */ 

/* In: const Intl6* pcm -> input frame of 16bit PCM samples */ 

/* */ 

void PsapRxUplink (const Intl6 *pcm) 

/* UTILITY FUNCTION: PsapRxDownlink */ 

/* */ 

/* Description: PSAP DL state machine, determines PSAP transmitter operation */ 
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/* according to the state */ 

/* */ 

void PsapRxDownlink ( ) 

/* PSAP FUNCTION: PsapReceiver */ 

/* */ 

/* Description: PSAP receiver function (decoding is done outside) */ 

/* */ 

/* In: const ModState* ms -> modulator struct */ 

/* const Intl6* pern -> input data for demodulation */ 

/* Out: IntLLR* softBits <- demodulated soft bit sequence */ 

/* */ 

void PsapReceiver (const ModState *ms, const Intl6 *pcm, IntLLR *softBits) 

/* PSAP FUNCTION: SymbolDemod */ 

/* */ 

/* Description: symbol demodulator */ 

/* */ 

/* In: const ModState* ms -> modulator struct */ 

/* const Intl6* mPulse -> received pulse train */ 

/* Out: IntLLR* softBits <- demodulated soft bit sequence */ 

/* */ 

void SymbolDemod (const ModState *ms, const Intl6 *mPulse, IntLLR *softBits) 

/* PSAP FUNCTION: Bit2Byte */ 

/* */ 

/* Description: conversion bit vector to byte vector */ 

/* */ 

/* In: const Ordl* in -> vector of input bits */ 

/* Intl6 length -> length of output */ 

/* Out: OrdS* out <- vector of output bytes */ 

/* */ 

void Bit2Byte (const Ordl *in, OrdS *out, Intl6 length) 

/* PSAP FUNCTION: MpyLacc */ 

/* */ 

/* Description: multiply 32bit number with 16bit number (32bit result) */ 

/* */ 

/* In: Int32 var32 -> 32bit number */ 

/* Intl6 varl6 -> 16bit number */ 

/* Return: Int32 <- result */ 

/* */ 

Int32 MpyLacc (Int32 var32, Intl6 varl6) 

/* DECODER FUNCTION: FecDecode */ 

/* */ 

/* Description: decoding to find the MSD */ 

/* */ 

/* In: const IntLLR* in -> received soft bits */ 

/* Intl6 rv -> redundancy version */ 

/* Out: Ordl* out <- decoded MSD in binary representation */ 

/* Return: Bool <- result of CRC check */ 

/* */ 

Bool FecDecode (const IntLLR *in, Intl6 rv, Ordl *out) 

/* DECODER FUNCTION: UpdateBuffer */ 

/* */ 

/* Description: update channel LLR buffer with new soft bits */ 
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/* */ 

/* In: const IntLLR* softlnBits -> received soft bits */ 

/* Intl6 rv -> redundancy version */ 

/* InOut : IntLLR* chLLRbuffer <-> decoder buffer */ 

/* */ 

void UpdateBuffer (IntLLR *chLLRbuf f er , const IntLLR *softInBits, Intl6 rv) 

/* DECODER FUNCTION: DecodeBuffer */ 

/* */ 

/* Description: decoding of LLR buffer */ 

/* */ 

/* In: const IntLLR* systl - > RX systematic soft bits */ 

/* const IntLLR* syst2 -> interleaved RX systematic tail bits */ 

/* const IntLLR* parityl - > RX parity soft bits */ 

/* const IntLLR* parity2 -> interleaved RX parity soft bits */ 

/* Out: Ordl* decBits <- decoded bits */ 

void DecodeBuffer (const IntLLR *systl, const IntLLR *syst2, 

const IntLLR *parityl, const IntLLR *parity2, Ordl *decBits) 

/* DECODER FUNCTION: Bcjr */ 

/* */ 

/* Description: BCJR algorithm */ 

/* */ 

/* In: const IntLLR* parity -> received parity soft bits */ 

/* InOut : IntLLR* extrinsic <-> extrinsic information */ 

/* */ 

void Bcjr (const IntLLR *parity, IntLLR *extrinsic) 

/*^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/ 

/* DECODER FUNCTION: Interleave */ 

/* */ 

/* Description: Turbo code interleaver */ 

/* */ 

/* In: const IntLLR* in -> input sequence */ 

/* Out: IntLLR* out <- output sequence */ 

/* */ 

void Interleave (const IntLLR *in, IntLLR *out) 

/* DECODER FUNCTION: Deinterleave */ 

/* */ 

/* Description: Turbo code deinterleaver */ 

/* */ 

/* InOut: IntLLR* inout <-> input and deinterleaved output sequence */ 

/* */ 

void Deinterleave (IntLLR * inout) 

/* DECODER FUNCTION: Descramble */ 

/* */ 

/* Description: descrambles decoded bits */ 

/* */ 

/* InOut: Ordl* inout <-> input and output bit sequence */ 

/* */ 

void Descramble (Ordl *inout) 

/* DECODER FUNCTION: DecodeCrc */ 

/* */ 

/* Description: check CRC of decoded bits */ 
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/* In: const Ordl* codedBits -> decoded bit sequence to be checked */ 

/* Return: Bool <- result of CRC check */ 

/* */ 

Bool DecodeCrc (const Ordl *codedBits) 

/* DECODER FUNCTION: GammaQ */ 

/* */ 

/* Description: compute gamma values for BCJR algorithm */ 

/* */ 

/* In: Intl6 k -> bit position */ 

/* Intl6 1 -> state */ 

/* const IntLLR* parity -> received parity bits */ 
/* const IntLLR* extrinsic -> sum of extrinsic and systematic bits */ 

/* Return: IntLLR <- value of gamma (k,l) */ 

/* */ 

IntLLR GammaQ (Intl6 k, Intl6 1, const IntLLR *parity, const IntLLR *extrinsic) 

/*============================================================================*/ 

/* UTILITY FUNCTION: JacLog */ 

/* */ 

/* Description: Jacobian logarithm */ 

/* */ 

/* In: IntLLR a -> value one */ 

/* IntLLR b -> value two */ 

/* Return: IntLLR <- Jacobian logarithm */ 

/* */ 

IntLLR JacLog (Int32 a, Int32 b) 



4.4.4 PSAP transmitter functions 

See control link functions. 

4.4.5 IVS receiver functions 

See control link functions. 

4.4.6 Synchronization functions (IVS and PSAP) 

/* FUNCTION: Sync */ 

/* */ 

/* Description: main synchronization function */ 

/* */ 

/* InOut : SyncState* sync <-> sync struct */ 

/* In: const Intl6* pcm -> input frame */ 

/* const char* caller -> modem identification */ 

/* */ 

void Sync (SyncState *sync, const Intl6 *pcm, const char *caller) 

/* UTILITY FUNCTION: CtrlSync */ 

/* */ 

/* Description: control message sync function */ 

/* */ 

/* InOut : CtrlRxData* control <-> control struct */ 

/* In: const Intl6* pcm -> input frame of 16bit PCM samples */ 

void CtrlSync (CtrlRxData *control, const Intl6 *pcm) 



ETSI 



3GPP TS 26.268 version 9.0.0 Release 9 



22 



ETSI TS 126 268 V9.0.0 (2010-01) 



/* IVS FUNCTION: SyncCheck */ 

/* */ 

/* Description: check whether locked sync is still valid */ 

/* */ 

/* InOut : SyncState* sync <-> sync struct */ 

/* In: const Intl6* pern -> input frame */ 

/* const char* caller -> modem identification */ 

/* */ 

void SyncCheck (SyncState *sync, const Intl6 *pcm, const char *caller) 

/* UTILITY FUNCTION: ToneDetect */ 

/* */ 

/* Description: tone detection at 500 Hz or 800 Hz */ 

/* */ 

/* InOut : SyncState* sync <-> sync struct */ 

/* In: const Intl6* pcm -> input frame */ 

/* */ 

void ToneDetect (SyncState *sync, const Intl6 *pcm) 

/* UTILITY FUNCTION: UpdatePeak */ 

/* */ 

/* Description: update sync peak position */ 

/* */ 

/* In: const Int32* pos -> vector of positions */ 

/* const Int32* corr -> vector of correlation values */ 

/* Intl6 dist -> distance to be checked */ 

/* Return: Intl6 <- updated peak position */ 

/* */ 

Intl6 UpdatePeak (const Int32 *pos, const Int32 *corr, Intl6 dist) 

/* UTILITY FUNCTION: CheckPosPeaks */ 

/* */ 

/* Description: check positive sync peaks */ 

/* */ 

/* InOut: SyncState* sync <-> sync struct */ 

/* In: const char* caller -> modem identification */ 

/* const Int32* pCorr -> vector of correlation values */ 

/* Intl6 pi -> peak position pi */ 

/* Intl6 p2 -> peak position p2 */ 

/* Intl6 ppPeaks -> number correct pos/pos distances */ 

/* Intl6 npPeaks -> number correct neg/pos distances */ 

/* Intl6 targetDelay -> target delay if sync successful */ 

/* */ 

void CheckPosPeaks (SyncState *sync, const char *caller, const Int32 *pCorr, 
Intl6 pi, Intl6 p2 , Intl6 ppPeaks, Intl6 npPeaks, 
Intl6 targetDelay) 

/* UTILITY FUNCTION: CheckNegPeaks */ 

/* */ 

/* Description: check negative sync peaks */ 

/* */ 

/* InOut: SyncState* sync <-> sync struct */ 

/* In: const char* caller -> modem identification */ 

/* const Int32* nCorr -> vector of correlation values */ 

/* Intl6 nl -> peak position nl */ 

/* Intl6 n2 -> peak position n2 */ 

/* Intl6 nnPeaks -> number correct neg/neg distances */ 

/* Intl6 npPeaks -> number correct neg/pos distances */ 

/* Intl6 targetDelay -> target delay if sync successful */ 
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/* */ 

void CheckNegPeaks (SyncState *sync, const char *caller, const Int32 *nCorr, 

Intl6 nl, Intl6 n2 , Intl6 nnPeaks, Intl6 npPeaks, 

Intl6 targetDelay) 



/* UTILITY FUNCTION: SyncReset */ 

/* */ 

/* InOut : SyncState* sync <-> sync struct */ 

/* In: Int32* mem -> pointer to sync memory */ 

/* Int3 2* memWakeup -> pointer to sync wakeup memory */ 

void SyncReset (SyncState *sync, Int32 *mem, Int32 *memWakeup) 



4.4.7 Control link functions 

/* CONTROL FUNCTION: CtrlTxProcess */ 

/* */ 

/* Description: process function control transmitter */ 

/* */ 

/* InOut : CtrlTxData* control <-> control struct */ 

/* Intl6* pcm <-> frame of 16bit PCM samples */ 

/* */ 

void CtrlTxProcess (CtrlTxData *control, Intl6 *pcm) 

/* UTILITY FUNCTION: CtrlTxMod */ 

/* */ 

/* Description: control message transmitter using prestored sequences */ 

/* */ 

/* In: Intl6 symbol -> lower- layer or higher- layer message symbol */ 

/* Intl6 index -> position within message frame */ 

/* Out: Intl6* pcm <- output data */ 

/* */ 

void CtrlTxMod (Intl6 *pcm, Intl6 symbol, Intl6 index) 

/* CONTROL FUNCTION: CtrlRxProcess */ 

/* */ 

/* Description: process function control receiver */ 

/* */ 

/* InOut: CtrlRxData* control <-> control struct */ 

/* In: const Intl6* pcm -> input frame of 16bit PCM samples */ 

/* */ 

void CtrlRxProcess (CtrlRxData *control, const Intl6 *pcm) 

/* UTILITY FUNCTION: CtrlRxDemod */ 

/* */ 

/* Description: control message receiver */ 

/* */ 

/* In: const Intl6* pcm -> input PCM buffer */ 

/* Out: Intl6* metric <- reliability factor (-1: skip) */ 

/* Return: Intl6 <- demodulated message */ 

/* */ 

Intl6 CtrlRxDemod (const Intl6 *pcm, Intl6 *metric) 

/* CONTROL FUNCTION: CtrlTxReset */ 

/* */ 

/* Description: reset function control transmitter */ 



ETSI 



3GPP TS 26.268 version 9.0.0 Release 9 24 ETSI TS 126 268 V9.0.0 (2010-01) 

/* */ 

/* InOut : CtrlTxData* control <-> control struct */ 

/* In: const char* owner -> modem identification */ 

/* */ 

void CtrlTxReset (CtrlTxData *control, const char *owner) 

/* CONTROL FUNCTION: CtrlRxReset */ 

/* */ 

/* Description: reset function control receiver */ 

/* */ 

/* InOut : CtrlRxData* control <-> control struct */ 

/* In: const char* owner -> modem identification */ 

/* SyncState* sync -> pointer to sync struct */ 

/* Intl6* buffer -> pointer to control receiver buffer */ 

/* Intl6 syncLock -> number of sync events required */ 

void CtrlRxReset (CtrlRxData *control, const char *owner, 

SyncState *sync, Intl6 *buffer, Intl6 syncLock) 



4.4.8 Other utility functions (IVS and PSAP) 

/* UTILITY FUNCTION: SetModState */ 

/* */ 

/* Description: set the modulator state */ 

/* */ 

/* In: Intl6 modType -> type of modulator to use */ 

/* InOut: ModState* ms <-> modulator struct */ 

/* */ 

void SetModState (ModState *ms, ModType modType) 
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